<template>
  <div class="user-edit">

    <!-- Drawer抽屉 -->
<!--    <Drawer-->
<!--      :title="title"-->
<!--      v-model="visible"-->
<!--      width="720"-->
<!--      draggable-->
<!--      :mask-closable="type == '0'"-->
<!--    >-->
      <div :style="{ maxHeight: maxHeight }" class="drawer-content">
        <div class="drawer-header">
          <div style="margin-right: 16px">基础信息</div>
          <Avatar :src="form.avatar" size="large" v-show="type != '2'" />
        </div>
        <Form label-colon v-show="type != '2'">
          <Row :gutter="32">
            <Col span="12">
              <FormItem label="用户ID">
                {{ form.id }}
                <Tooltip trigger="hover" placement="right" content="账户已禁用">
                  <Icon
                    v-show="form.status == -1"
                    type="md-lock"
                    size="18"
                    style="margin-left: 10px; cursor: pointer"
                  />
                </Tooltip>
              </FormItem>
            </Col>
            <Col span="12">
              <FormItem label="用户名">
                {{ form.username }}
                <Tooltip
                  trigger="hover"
                  placement="right"
                  :content="`密码强度：${form.passStrength}`"
                >
                  <Icon
                    v-show="form.passStrength"
                    type="md-key"
                    :color="passColor"
                    size="18"
                    style="margin-left: 10px; cursor: pointer"
                  />
                </Tooltip>
              </FormItem>
            </Col>
          </Row>
        </Form>
        <Form
          ref="form"
          :model="form"
          :rules="formValidate"
          label-position="top"
        >
          <Row :gutter="32" v-if="type == '2'">
            <Col span="24">
              <FormItem label="用户名" prop="username" style="position:relative;">
                <Input
                  v-model="form.username"
                  autocomplete="off"
                  :maxlength="16"
                />
                <input type="text" style="position: fixed;z-index: -10000;width: 0;border: none"></input>
              </FormItem>
            </Col>
            <Col span="24">
              <FormItem label="密码" prop="password">
                <SetPassword v-model="form.password" @on-change="changePass" />
              </FormItem>
            </Col>
          </Row>
          <Row :gutter="32">
            <Col span="24">
              <FormItem label="姓名" prop="nickname">
                <Input v-model="form.nickname" />
              </FormItem>
            </Col>
<!--            <Col span="12" style="display: none">-->
<!--              <FormItem label="手机号" prop="mobile">-->
<!--                <Input v-model="form.mobile" />-->
<!--              </FormItem>-->
<!--            </Col>-->
          </Row>
<!--          <Row :gutter="32">-->
<!--            <Col span="12">-->

<!--              <FormItem label="邮箱">-->
<!--                &lt;!&ndash;              <FormItem label="邮箱" prop="email">&ndash;&gt;-->
<!--                <Input v-model="form.email" transfer />-->
<!--              </FormItem>-->
<!--            </Col>-->
<!--            <Col span="12">-->
<!--              <FormItem label="性别">-->
<!--                <dict dict="sex" v-model="form.sex" transfer />-->
<!--              </FormItem>-->
<!--            </Col>-->
<!--          </Row>-->
          <Row :gutter="32">
            <Col span="24">
              <FormItem label="所属部门" class="form-noheight">
                <department-tree-choose
                  @on-change="handleSelectDepTree"
                  ref="depTree"
                ></department-tree-choose>
              </FormItem>
            </Col>
<!--            <Col span="12">-->
<!--              <FormItem label="用户类型">-->
<!--                <Select  v-model="form.type" transfer placeholder="请选择">-->
<!--                  <Option :value="0">普通用户</Option>-->
<!--                  <Option :value="1">管理员</Option>-->
<!--                </Select>-->
<!--              </FormItem>-->
<!--            </Col>-->
            <Col span="24">
              <FormItem label="头像" class="form-noheight">
                <upload-pic-input v-model="form.avatar"></upload-pic-input>
              </FormItem>
            </Col>
          </Row>
          <Row :gutter="32">

            <Col span="24">
              <FormItem label="角色分配" prop="roleIds">
                <Select v-model="form.roleIds" multiple transfer>
                  <Option
                    v-for="item in roleList"
                    :value="item.id"
                    :key="item.id"
                    :label="item.description"
                  >
                    <span style="margin-right: 10px">{{ item.name }}</span>
                    <span style="color: #ccc">{{ item.description }}</span>
                  </Option>
                </Select>
              </FormItem>
            </Col>
          </Row>
<!--          <Divider />-->
<!--          <p class="drawer-title">个人资料</p>-->
<!--          <Row :gutter="32">-->
<!--            <Col span="12">-->
<!--              <FormItem label="所在地区" prop="address">-->
<!--                <al-cascader-->
<!--                  v-model="form.address"-->
<!--                  data-type="name"-->
<!--                  level="2"-->
<!--                  transfer-->
<!--                />-->
<!--              </FormItem>-->
<!--            </Col>-->
<!--            <Col span="12">-->
<!--              <FormItem label="街道地址">-->
<!--                <Input v-model="form.street" />-->
<!--              </FormItem>-->
<!--            </Col>-->
<!--          </Row>-->
<!--          <Row :gutter="32">-->
<!--            <Col span="12">-->
<!--              <FormItem label="生日" prop="birth">-->
<!--                <DatePicker-->
<!--                  v-model="form.birth"-->
<!--                  style="display: block"-->
<!--                  type="date"-->
<!--                  transfer-->
<!--                ></DatePicker>-->
<!--              </FormItem>-->
<!--            </Col>-->
<!--            <Col span="24">-->
<!--              <FormItem label="简介">-->
<!--                <Input type="textarea" v-model="form.description" :rows="4" />-->
<!--              </FormItem>-->
<!--            </Col>-->
<!--          </Row>-->
        </Form>
      </div>
      <div class="drawer-footer br">
        <Button  v-show="type != '0'" type="primary" :loading="submitLoading" @click="submit"
          >提交</Button
        >
        <Button @click="visible = false">取消</Button>
      </div>
<!--    </Drawer>-->
  </div>
</template>

<script>
import { getAllRoleList, addUser, editUser } from "@/api/index";
import {
  validateUsername,
  validateMobile,
  validatePassword,
} from "@/libs/validate";
import departmentTreeChoose from "@/views/my-components/xboot/department-tree-choose";
import uploadPicInput from "@/views/my-components/xboot/upload-pic-input";
import SetPassword from "@/views/my-components/xboot/set-password";
import dict from "@/views/my-components/xboot/dict";
export default {
  name: "user",
  components: {
    departmentTreeChoose,
    uploadPicInput,
    SetPassword,
    dict,
  },
  props: {
    value: {
      type: Boolean,
      default: false,
    },
    data: {
      type: Object,
    },
    type: {
      type: String,
      default: "0",
    },
  },
  data() {
    return {
      roleList: [],
      visible: this.value,
      title: "",
      passColor: "",
      submitLoading: false,
      maxHeight: 510,
      form: {
        type:0,
        address: [],
      },
      formValidate: {
        // 表单验证规则
        username: [
          { required: true, message: "请输入用户名", trigger: "change" },
          { validator: validateUsername, trigger: "change" },
        ],
        nickname: [
          { required: true, message: "请输入姓名", trigger: "change" },
        ],
        // mobile: [
        //   { required: true, message: "请输入手机号", trigger: "change" },
        //   { validator: validateMobile, trigger: "change" },
        // ],
        password: [
          { required: true, message: "请输入密码", trigger: "blur" },
          { validator: validatePassword, trigger: "blur" },
        ],
        // email: [
        //   { required: true, message: "请输入邮箱地址" },
        //   { type: "email", message: "邮箱格式不正确" },
        // ],
      },
    };
  },
  methods: {
    init() {
      this.getRoleList();
    },
    getRoleList() {
      getAllRoleList().then((res) => {
        if (res.success) {
          this.roleList = res.result;
        }
      });
    },
    handleSelectDepTree(v) {
      this.form.departmentId = v;
    },
    changePass(v, grade, strength) {
      console.log(v,grade,strength,'-----sssss')
      this.form.passStrength = strength;
      this.form.password=v
    },
    submit() {
      this.$refs.form.validate((valid) => {
        if (valid) {
          // this.form.mobile = this.getMockMobile();
          if (typeof this.form.birth == "object") {
            this.form.birth = this.format(this.form.birth, "yyyy-MM-dd");
          }
          if (this.type == "1") {
            // 编辑
            this.submitLoading = true;
            editUser(this.form).then((res) => {
              this.submitLoading = false;
              if (res.success) {
                this.$Message.success("操作成功");
                this.$emit("on-submit", true);
                this.visible = false;
              }
            });
          } else {
            // 添加
            this.submitLoading = true;
            console.log(this.form,"kkk")
            addUser(this.form).then((res) => {
              this.submitLoading = false;
              if (res.success) {
                this.$Message.success("操作成功");
                this.$emit("on-submit", true);
                this.visible = false;
              }
            });
          }
        }
      });
    },
    setCurrentValue(value) {
      if (value === this.visible) {
        return;
      }
      if (this.type == "1") {
        this.title = "编辑用户";
        this.maxHeight =
          Number(document.documentElement.clientHeight - 121) + "px";
      } else if (this.type == "2") {
        this.title = "添加用户";
        this.maxHeight =
          Number(document.documentElement.clientHeight - 121) + "px";
      } else {
        this.title = "用户详情";
        this.maxHeight = "100%";
      }
      // 清空数据
      this.$refs.form.resetFields();
      if (this.type == "0" || this.type == "1") {
        // 回显数据
        let data = this.data;
        // 地址
        if (data.address) {
          data.address = data.address.split(",");
        } else {
          data.address = [];
        }
        // 部门
        // this.$refs.depTree.setData(data.departmentId, data.departmentTitle);
        // 角色
        let selectRolesId = [];
        data.roles.forEach(function (e) {
          selectRolesId.push(e.id);
        });
        data.roleIds = selectRolesId;
        delete data.roles;
        delete data.permissions;
        // 密码强度
        if (data.passStrength == "弱") {
          this.passColor = "#ed3f14";
        } else if (data.passStrength == "中") {
          this.passColor = "#faad14";
        } else if (data.passStrength == "强") {
          this.passColor = "#52c41a";
        }
        // 回显
        this.form = data;

      } else {
        // // 添加
        // this.$refs.depTree.setData("", "");
        // this.form = {
        //   type: 0,
        //   sex: "",
        //   address: [],
        // };
      }
      this.visible = value;
    },
    // 生成假手机号
    getMockMobile() {
      const mobilePrefix = "152";
      let mobileSuffix = "";
      for (let i = 0; i < 8; i++) {
        mobileSuffix += Math.floor(Math.random() * 10);
      }
      // console.log(mobilePrefix + mobileSuffix);
      return mobilePrefix + mobileSuffix;
    },
  },
  watch: {
    value(val) {
      this.setCurrentValue(val);
    },
    visible(value) {
      // if(value){
      //   this.form={}
      // }
      this.$emit("input", value);
    },
  },
  mounted() {
    this.init();
  },
};
</script>

<style lang="less">
@import "../../../styles/drawer-common.less";
</style>

